# Two-Layer Bus Routing for High-Speed Printed Circuit Boards

MUHAMMET MUSTAFA OZDAL
Intel Corporation
and
MARTIN D. F. WONG
University of Illinois at Urbana-Champaign

The increasing clock frequencies in high-end industrial circuits bring new routing challenges that cannot be handled by traditional algorithms. An important design automation problem for high-speed boards today is routing nets within tight minimum and maximum length bounds. In this article, we propose an algorithm for routing bus structures between components on two layers such that all length constraints are satisfied. This algorithm handles length extension simultaneously during the actual routing process so that maximum resource utilization is achieved during length extension. Our approach here is to process one track at a time, and choose the best subset of nets to be routed on each track. The algorithm we propose for single-track routing is guaranteed to find the optimal subset of nets together with the optimal solution with length extension on one track. The experimental comparison with a recently proposed technique shows the effectiveness of this algorithm both in terms of solution quality and run-time.

Categories and Subject Descriptors: B.7.2 [Integrated Circuits]: Design Aids—Placement and routing

General Terms: Algorithms, Design, Theory

Additional Key Words and Phrases: High-speed, PCB, bus routing, min-max length constraints

A preliminary version of this article appeared in *Proceedings of the 2004 IEEE International Conference on Computer Design (ICCD'04)*, IEEE Computer Society Press, Los Alamitos, CA, October 2004, pp. 99–105.

This work was partially supported by the National Science Foundation under Grant CCR-0306244, and by an IBM Faculty Partnership Award.

Based on "A Two-Layer Bus Routing Algorithm for High-Speed Boards" by Muhammet Mustafa Ozdal and Martin D. F. Wong, which appeared in *Proceedings of the 2004 IEEE International Conference on Computer Design (ICCD'04)*. ©2004 IEEE.

Authors' addresses: M. M. Ozdal, 2111 N.E. 25th Ave., Hillsboro, OR 97124; email: mustafa.ozdal@intel.com; M. D. F. Wong, University of Illinois at Urbana-Champaign, 201 North Goodwin Ave., Urbana, IL 61801-2302.

Permission to make digital or hard copies of part or all of this work for personal or classroom use is granted without fee provided that copies are not made or distributed for profit or direct commercial advantage and that copies show this notice on the first page or initial screen of a display along with the full citation. Copyrights for components of this work owned by others than ACM must be honored. Abstracting with credit is permitted. To copy otherwise, to republish, to post on servers, to redistribute to lists, or to use any component of this work in other works requires prior specific permission and/or a fee. Permissions may be requested from Publications Dept., ACM, Inc., 1515 Broadway, New York, NY 10036 USA, fax: +1 (212) 869-0481, or permissions@acm.org.

© 2006 ACM 1084-4309/06/0100-0213 \$5.00

 $ACM\ Transactions\ on\ Design\ Automation\ of\ Electronic\ Systems,\ Vol.\ 11,\ No.\ 1,\ January\ 2006,\ Pages\ 213-227.$ 

## 1. INTRODUCTION

During the past several years, we have seen dramatic increases in the clock frequencies of industrial circuits. As the circuits become smaller and faster, the routing problems become more and more difficult, and the designers face new challenges, most of which cannot be handled by the traditional routing algorithms. Many high-end board designs in the industry today need to be routed manually, since the existing routing tools are usually ineffective for high-end circuits.

Routing nets within minimum and maximum length bounds is an important requirement for high-speed VLSI layouts. There have been several algorithms proposed for the objective of minimizing path lengths, or satisfying prespecified maximum length constraints, especially in the context of timing-driven routing [Kuh et al. 1987; Dunlop et al. 1984; Boese et al. 1992; Prastjutrakul and Kubitz 1990; Cong et al. 1992; Lee and Wong 2003]. However, the problem of routing nets with lower bound constraints has not been studied extensively in the literature. The main reason is that these bounds were loose most of the time, and nonsophisticated ad hoc strategies (such as greedy length extension in post-processing) were sufficient for most applications. However, as circuits start to use clock frequencies in the order of gigahertz in the current technology, the timing constraints become extremely tight, and more aggressive methods for achieving length bounds are needed in the industrial applications.

We have been working on a project to develop a routing system for high-end IBM board designs, where a typical board contains several bus structures between MCM, memory and I/O modules, in addition to individual nets. Data is clocked into registers or other circuits in a typical bus structure; so all signals traveling over different wires of the bus must arrive at their destinations approximately at the same time. To achieve this, all the wires constituting this bus need to have approximately the same length. The precision with which matching must be done is directly related to the clock frequency [Ritchey 2000]. As the clock frequency increases, the skew requirements on the propagation delays become more strict, and so a higher degree of length matching is required. Note here that this problem is completely different from the minimum-skew clock tree routing problem, which has been studied extensively in the literature [Huang et al. 1995; Kahng and Robins 1995; Cong et al. 1998; Tsao and Koh 2002]. The difference here is that a bus consists of a large number of different two-terminal nets, as opposed to a single net with multiple terminals. The objective here is to find independent routing solutions for each net while satisfying all length constraints. Furthermore, there may be more than one bus structures interleaved with each other, or there may be individual nets not belonging to any bus. So, we will consider the general case where each net has individual min-max length constraints assigned to it.

In this article, we focus on a two-layer bus routing problem, where each layer has a primary routing direction of either horizontal or vertical. A sample routing solution is illustrated in Figure 1, where there are two bus structures: (1) a vertical bus between MCM and I/O module, and (2) a horizontal bus between





Fig. 1. A typical two-layer routing solution. There are two separate bus structures here: (1) between MCM and I/O, and (2) between MCM and memory. No length extension (to satisfy min-length constraints) has been performed yet.

MCM and memory module. Observe in the horizontal layer that the congestion in the area corresponding to the vertical problem (i.e., the area between MCM and I/O) is considerably lower than the congestion in the area corresponding to the horizontal problem (i.e., the area between MCM and MEM), and vice-versa. The main reason is that the horizontal distance between terminals of a net in a horizontal problem corresponds to the distance between two different components, and it is typically much larger than the respective vertical distance.

Routability in a highly congested area is expected to be limited; so it will be more effective to perform length extension (to satisfy min-length constraints) within the less congested areas. For example, the vertical layer of a horizontal problem is expected to be significantly less congested; so it makes more sense to perform length extension on this layer. In this paper, we propose an algorithm that incorporates the objective of length extension into the actual routing algorithm. For a horizontal problem, our algorithm simultaneously extends the lengths of the nets and assigns them to vertical tracks.

Recently, a general Lagrangian relaxation framework has been proposed for satisfying min-max length constraints of printed circuit boards [Ozdal and Wong 2003]. Although the target class of problems of that framework is more general, our algorithm has distinct advantages for the bus routing problem described above. First of all, we route multiple nets simultaneously on one track in an optimal way, instead of using a net-by-net approach, which has no theoretical guarantees. Furthermore, the routing solutions are more uniform in our algorithm. That is, all nets use two vias, and the number of bends (due to length extension) is at most 4 for each net. Also, we consider a certain type of length extension methodology here, which is especially effective for this problem.

The rest of the article is organized as follows. In Section 2, we describe the target problem in more detail, and discuss why simple ad hoc methodologies are not sufficient for this problem. Then, we propose an algorithm in Section 3 based on some assumptions about input circuits. In Section 4, we relax these assumptions, and discuss how to generalize this algorithm. Finally, we perform experiments in Section 5 to show the effectiveness of our algorithm compared to the Lagrangian relaxation framework [Ozdal and Wong 2003].



Fig. 2. A sample routing solution on two layers, where each net has individual min-max length constraints. The terminals for 12 nets are aligned on the left and right side of the channel. Two vias (represented as empty circles) are used to route each net. The dashed lines on layer 2 indicate the length extension performed to satisfy min-length constraints.

## 2. PROBLEM FORMULATION AND MOTIVATION

For a given set of nets  $\mathcal{N}$ , and min-max length constraints  $T_i^{\min}$ ,  $T_i^{\max}$  for each net i, our purpose is to find a two-layer routing solution such that all length constraints are satisfied, and the routing resources are utilized most effectively. We assume that routing within dense components (escape routing) has already been accomplished by the earlier stages of the routing system; hence all terminals are now aligned on the opposite sides of the channel. At first glance, this problem may seem similar to the traditional channel routing problem [Hashimoto and Stevens 1971; Yoshimura and Kuh 1982; Rivest and Fiduccia 1982; Burstein and Pelavin 1983], which has been studied extensively in the literature. However, the existence of min-max length constraints due to the high-speed design rules makes this problem significantly different from the traditional problem.

For simplicity of presentation, we will first focus on a restricted problem instance, where (1) each pair of adjacent terminals is separated by at least one grid cell on each side, and (2) there are no obstacles within the routing area. The algorithms we propose in Section 3 will be based on these assumptions; however, we will extend our algorithms in Section 4 for the general case.

All algorithms in this article will be presented for a horizontal problem (i.e., terminals are aligned on the left and right sides of the channel); however, it is trivial to modify them for a vertical problem. Let us denote the horizontal routing layer as the *primary layer* and the vertical routing layer as the *secondary layer*. As mentioned before, since routing resources are very scarce on the primary layer, length extension will be performed on the secondary layer to satisfy all min-length constraints.

Figure 2 illustrates a sample routing solution for 12 nets, where the dashed lines indicate length extension performed on each net. Observe that layers 1 and 2 are primarily for routing horizontal and vertical segments, respectively.



Fig. 3. Alternative routing solutions corresponding to Figure 2, if (a) length extension is performed in post-processing, and (b) length extension is performed in preprocessing. In (a), min-length constraints of nets 1, 5, 7 and 9 are violated. In (b), the number of vertical tracks necessary increases to 8 (from 5). For clarity, only the results on the secondary layer are illustrated.

However, small deviations from the primary directions are allowed on each layer. For instance, there are small diagonal segments (for alignment) on layer 1 and small horizontal segments (for length extension) on layer 2. Furthermore, the second layer is defined to consist of *vertical tracks*, where each track has width equal to the sum of via diameter and wire width (plus clearance between them). For example, five vertical tracks are used on layer 2 of this figure. Note that via diameters are typically much larger than wire widths, so the increase in track widths due to length extension is normally negligible.

It is important here to note that length extension needs to be performed simultaneously while determining the positions of vertical segments on the secondary layer. In the example of Figure 2, the number of vertical tracks used is kept minimum (i.e., five vertical tracks used on the second layer), and the routing resources are utilized most effectively. However, this utilization will be significantly reduced if length extension is performed as a separate step in the routing process. For instance, one can use a traditional channel routing algorithm (such as left-edge algorithm [Hashimoto and Stevens 1971]) first to assign routing segments to the vertical tracks, and then extend the lengths of vertical segments in post-processing. Figure 3(a) shows the corresponding solution of the left-edge algorithm. Observe that segments have been assigned to vertical tracks without considering the min-length constraints. So, it is not guaranteed that there is enough space around each net such that its length will be successfully extended in post-processing. For instance, consider net 5 in this figure, which is assigned to the second vertical track between the segments of nets 1 and 7. Obviously, its length cannot be extended in post-processing (due to lack of space), and its min-length constraint will be violated. Specifically, there are 4 nets in this example of which length constraints will not be satisfied even after post-processing: nets 1, 5, 7, and 9. This example clearly demonstrates that min-length constraints need to be considered during the actual routing process, not just as a post-processing step.

Another approach here can be to extend the lengths of vertical segments using a predefined pattern in preprocessing, and then to apply a traditional channel routing algorithm to assign them to vertical channels. Figure 3(b) shows such an example, where segments have been extended (from bottom) first; then the left edge algorithm has been applied on the extended segments. The disadvantage of this approach is that the routing algorithm has no control over the length extension process; so the resulting solution cannot utilize the routing resources most efficiently. In this example, eight vertical tracks are used to obtain a feasible solution, while Figure 2 shows that five tracks would be sufficient to satisfy all length constraints. This example shows that performing length extension as a preprocessing step is also not an effective strategy.

The algorithms we propose in this article handle length extension and track assignment simultaneously, so that a feasible routing solution is obtained while using minimum number of vertical tracks. For instance, observe in Figure 2 that net 1 is extended both from top and from bottom, and such an extension allows three nets to fit on one track. The next section describes our models and algorithms in more detail.

## 3. ALGORITHM DESCRIPTION

## 3.1 Routing Model

Routing on the horizontal layer is straightforward, because of the assumptions that there are no obstacles in the routing area and that each adjacent pair is separated by at least one grid cell (see Section 4 for the general case without these assumptions). As illustrated in the example of Figure 2, a horizontal connection<sup>1</sup> is possible from each terminal on one side of the channel to the other side, without any conflicts with others. So, the main problem here is to determine the positions of vertical segments on the secondary layer. Once the positions of these vertical segments are fixed, the horizontal segments on the first layer can be connected to them using vias, as illustrated in this example.

Figure 4 shows an example illustrating the way length extension is performed on vertical segments. Here, assume that we need to extend the length of the segment in part (a) by 16 units (in terms of grid cells) to satisfy its min-length constraint. Figure 4(b) shows eight possible configurations, each of which is the extended version of the original segment. As mentioned before, one via and one wire is defined to fit on a vertical track together; so each extended segment in this figure is defined to be on a single track. Figure 4(c) gives a simpler representation, where a solid line represents the original segment and a dashed line represents the extended length.

Min length constraint for a net directly determines the minimum length requirement for its vertical segment. Let  $x_i$  denote the amount of length extension required to satisfy min length constraint of net i. The value of  $x_i$  is simply equal to the Manhattan distance between net i's terminal points subtracted from its min length constraint. Here, the vertical segment of net i must be extended by

<sup>&</sup>lt;sup>1</sup>A small diagonal segment might be necessary to align the horizontal segments on opposite sides, as shown in Figure 2.



Fig. 4. (a) A vertical segment that needs to be extended by 16 units. (b) Eight possible configurations corresponding to the extended segment. (c) Each configuration is represented as a single line, where dashed lines represent the length extension.

at least  $x_i/2 - 1$  from top or from bottom, as in Figure 4(c). In the example of Figure 4,  $x_i$  is given as 16, and the vertical segment of net i needs to be extended by at least 7 units.<sup>2</sup>

These concepts are formalized by the following definitions:

Definition 3.1. The routing solution for net i is defined based on the position of its vertical segment, and it is denoted as  $R_i = (t_i, r_i, \ell_i)$ , where  $t_i$  is the track number,  $r_i$  is the top row, and  $\ell_i$  is the length of the vertical segment of net i. Here,  $\ell_i$  is determined directly from the min length constraint of net i, as discussed before. Furthermore,  $r_i$  must be chosen such that  $r_i^{\min} \leq r_i \leq r_i^{\max}$ , where  $r_i = r_i^{\min}$ , and  $r_i = r_i^{\max}$  correspond to the extreme cases where no length extension is performed from the bottom, and from the top, respectively. The main idea is illustrated in Figure 5.

Definition 3.2. The routing problem for a given set of nets is defined as finding a solution  $R_i = (t_i, r_i, \ell_i)$  for each net i such that (1) no two vertical segments on the same track overlap with each other, and (2) the number of vertical tracks used is minimized.

Note that the min length constraints are captured by the target length  $\ell_i$  defined for each net i, while the max length constraints do not need to be considered explicitly. The reason is that each net is routed using the minimum possible length in this algorithm.

# 3.2 Algorithm Proposed

The problem defined by Definitions 3.1 and 3.2 is actually a special case of the *task scheduling problem with release times and deadlines on a multi-computer*. Here, each vertical track can be considered as a computer; each vertical routing

<sup>&</sup>lt;sup>2</sup>As shown in Figure 4(b), the extended part actually consists of two adjacent vertical wire segments and one unit of horizontal wire segment. However, for simplicity, we represent it as a single wire as in part (c).



Fig. 5. Three different cases for the vertical segment of net i are illustrated. Here, length  $\ell_i$  is fixed, since it is determined by the min-length constraint. However, the top row  $r_i$  can vary between  $r_i^{\min}$  and  $r_i^{\max}$ . The solid and dashed lines here represent the original and extended segments, respectively.

segment can be considered as a task with length  $\ell_i$ , release time  $r_i^{\min}$ , and deadline  $r_i^{\max}$ . Note that this problem is known to be an NP-complete problem in the strong sense, even in the case where there is a single computer [Blazewicz et al. 2001]. However, the special property of our problem will allow us to give a polynomial-time exact algorithm for the single-track case.

Here, our approach will be to process one track at a time and to *pack* as many routing segments as possible on each track. Note that the best routing configuration for each net should also be determined simultaneously during this process. The following definition gives a formal description of this objective.

Definition 3.3. The problem of single-track assignment is defined as follows: Given a set of nets  $\mathcal{N}$ , and a set of vertical segments for each net i in  $\mathcal{N}$ , the objective is to select a subset of these vertical segments, such that (1) at most one vertical segment is selected corresponding to each net i, (2) the selected segments do not overlap with each other, and (3) maximum resource utilization is achieved on one track (i.e., the number of grid cells unused is kept minimum).

As an example, consider Figure 6(a), where there are 4 different nets, and each net has multiple routing configurations. The corresponding optimal solution for single-track assignment is shown in Figure 6(b). Observe that 21 out of 22 grid cells have been utilized on this track.

As mentioned above, this problem is a special case of the task scheduling problem on a single computer, which is an NP-complete problem in the strong sense. However, we propose an algorithm in Figure 7, which is guaranteed to find the optimal solution in polynomial time (due to the special property that will be given in Lemma 3.2). Here, the main idea is to represent each row of the track as a vertex, and to model each vertical segment as a zero-weight edge between the respective rows. Furthermore, there is a unit-weight edge from each v[j] to v[j+1], which corresponds to the case where the grid cell



Fig. 6. (a) A sample single-track assignment problem with 4 nets. Multiple routing configurations are illustrated for each net. (b) The optimal solution, which utilizes 21 out of 22 grid cells of one track. The dashed lines indicate the length extension performed.

```
SINGLE-TRACK-ASSIGNMENT (\mathcal{N}: set of nets, t: current track) create a graph \mathcal{G} as follows:
  for each row j of track t
  create a vertex v[j]
  add a unit-weight edge from v[j-1] to v[j]
  for each net i in \mathcal{N}
  for r_i = r_i^{\min} to r_i^{\max} do
   create a zero-weight edge from v[r_i] to v[r_i+\ell_i+1]

Compute the shortest path P from v[1] to v[\text{last}] in \mathcal{G}
  for each edge e \in P
  if e is a zero-weight edge from v[k] to v[m]
  select the vertical segment that spans rows from k to m-1
```

Fig. 7. Algorithm for selecting the maximal subset of non-overlapping vertical segments.

on row j is unused. Then, the shortest path from the first row to the last row is computed to find the optimal assignment with the maximum resource utilization. Intuitively, the weight of an edge from v[k] to v[m] indicates the number of grid cells that will be wasted between rows k and m-1 if this edge is selected. So, the shortest path from the top row to the bottom row will give us the assignment with the minimum waste. Figure 8 illustrates the graph model corresponding to the problem given in Figure 6(a). The highlighted path in this graph is the shortest path, and it corresponds to the optimal solution in Figure 6(b). For example, the edge from v[1] to v[6] on the shortest path corresponds to the vertical segment of net 2 from row 1 to row 5. The formal analysis of this algorithm is given as follows.

LEMMA 3.1. Consider any pair of edges  $e_i, e_j \in \mathcal{G}$ . If there exists a path P such that  $e_i, e_j \in P$ , then the vertical segments corresponding to  $e_i$  and  $e_j$  are guaranteed not to overlap with each other.



Fig. 8. The graph model corresponding to the problem of Figure 6(a). The edges corresponding to net segments (solid arrows) have zero weights, while the others (dashed arrows) have unit weights. The shortest path (with total weight 1) is highlighted, and it corresponds to the optimal solution in Figure 6(b).

PROOF. The direction of edges in  $\mathcal{G}$  are always towards larger vertex indices. Furthermore, for a vertical segment that spans rows k to m, the corresponding edge will be from v[k] to v[m+1]. Hence, any edge selected after this edge will correspond to a segment starting from row m+1. So, any pair of edges in a path cannot correspond to overlapping net segments.  $\square$ 

LEMMA 3.2. Consider the set of edges  $E_n$  corresponding to net n. There exists no path P in G such that  $e_i, e_j \in P$  and  $e_i, e_j \in E_n$ . In other words, a path cannot contain two edges corresponding to different vertical segments of the same net.

PROOF. There are different vertical segments corresponding to net n, because there are different ways of extending the length of n. However, as can be seen in Figure 5, the original segment (represented with solid lines) is always fixed; hence all vertical segments corresponding to the same net will overlap with each other. Also, from Lemma 3.1, a path cannot contain edges corresponding to overlapping net segments.  $\Box$ 

Theorem 3.3. The shortest path in G between the first and last vertices corresponds to the optimal solution of the single-track assignment problem defined in Definition 3.3.

Proof. From Lemmas 3.1 and 3.2, the set of edges on any path corresponds to a valid assignment on one track. Furthermore, there is a path in  $\mathcal{G}$ 

ACM Transactions on Design Automation of Electronic Systems, Vol. 11, No. 1, January 2006.



Fig. 9. In a typical board routing problem, nets escape from dense components (solid line segments), and the input to the bus routing problem is defined as a set of terminals aligned on the opposite sides of a channel. Since the diameters of the pins within components are much larger than wire widths, these terminals are typically well-separated. So, it is possible to align all horizontal segments (dashed lines) such that there are no overlaps between them.

corresponding to any valid assignment on one track. Since the unit weighted edges in  $\mathcal G$  correspond to the unused rows of the track, the total weight of path P will be equal to the number of rows wasted. So, the shortest path from the top row to the bottom row will correspond to the optimal assignment with maximum utilization.  $\square$ 

Theorem 3.4. Let H denote the number of rows in the channel, and  $x_i$  denote the amount of length extension required to satisfy min-length constraint of net i. The time complexity of the algorithm given in Figure 7 is  $O(H + \sum_{i \in N} x_i)$ .

PROOF. There are  $O(x_i)$  different vertical segments defined for each net. So, the number of edges in  $\mathcal{G}$  is  $O(H + \sum_{i \in N} x_i)$ , while the number of vertices is O(H). Furthermore,  $\mathcal{G}$  is a directed acyclic graph, and the shortest path can be computed in linear time [Cormen et al. 1992].  $\square$ 

## 4. GENERALIZATION OF THE ALGORITHM

In the previous section, we assumed that each pair of adjacent terminals is separated by at least one grid cell. However, this is not absolutely necessary, as long as it is possible to extend the horizontal segments from one side of the channel to the other side without any conflicts, as illustrated in Figure 9. If this is the case, then there will be no restrictions on the positions of the vertical segments, and the same algorithm in Section 3 can be used without a change. Note that this assumption is reasonable for a typical industrial circuit, since the pin diameters within chip components are much larger than the wire widths; so there will be enough routing space to align horizontal segments from both sides without any overlaps (as in Figure 9).

Actually, this corresponds to the unrestricted case of the original channel routing problem [Hashimoto and Stevens 1971], where there are no vertical constraints; that is, net segments can be assigned to tracks without any ordering constraints. On the other hand, if overlaps are possible on the horizontal layer, then we need to define *pin constraints* to avoid overlaps. For instance, assume that the horizontal segment of net *i* originating from a left terminal overlaps





Fig. 10. (a) The horizontal segments of a net are not entirely straight due to an obstacle. (b) The vertical segment is assigned on a track to the left of the obstacle. (c) The vertical segment is assigned on a track to the right of the obstacle. The solid and the dashed lines represent the routing segments on the horizontal and vertical layers, respectively. For clarity, only one net is displayed, and length extension on the vertical layer is not shown.

with the horizontal segment of net j originating from a right terminal. In that case, the vertical segment of net i must be assigned to a track which is to the left of the vertical segment of net j to avoid an overlap on the horizontal layer. Note that if there were no min-max length constraints, this would correspond to the problem of *channel routing with vertical constraints*, which has been studied in the literature. This problem has been shown to be NP-complete [LaPaugh 1980; Szymanski 1985]; however, there have been several algorithms proposed that give sufficiently good results [Rivest and Fiduccia 1982; Burstein and Pelavin 1983; Yoshimura and Kuh 1982; Fang et al. 1992]. If the assumption of well-separated terminals (mentioned above) is not valid for a circuit, we can use similar ideas to extend our algorithm to the general case. In particular, we can define pin constraints indicating the ordering of the vertical segments, and then perform track assignment based on this ordering. Since our algorithm processes one track at a time, we can simply consider the set of nets that do not violate the ordering constraints for the track that is being processed.

We can also generalize our algorithm to the case where there are some obstacles in the routing region. If the obstacles are on the horizontal layer, then the horizontal segments will not be entirely straight, as shown in Figure 10(a). Furthermore, the y coordinates of the vertical segments will depend on the track on which it is assigned, as illustrated in parts (b) and (c) of the same figure. Since the algorithm we propose processes one track at a time, the appropriate vertical segments corresponding to each net can be determined for each track, and the algorithm given in Figure 7 can still be used to choose the best subset. On the other hand, we can handle the obstacles on the vertical layer by simply removing the edges corresponding to vertical segments that overlap with an obstacle on the current track.

## 5. EXPERIMENTAL RESULTS

We have performed experiments to compare our algorithm with a recently proposed Lagrangian relaxation (LR) based approach [Ozdal and Wong 2003]. All algorithms in this section have been implemented in C++, and experiments were performed on an Intel Pentium 4 2.4-GHz system with 1-GB memory, and a Linux operating system.

A sample output of our algorithm is illustrated in Figure 11, for a routing problem with 128 nets. Here, each net has individual length constraints, and





Fig. 11. A sample two-layer solution for 128 nets. A vertical problem is illustrated here; hence length extension is performed on the horizontal (second) layer. The length constraints for all nets have been satisfied in this solution.

Table I. Comparison of Our Algorithm with the Lagrangian Relaxation Based Approach

|       | •       |        |                        |               |       |          |       |
|-------|---------|--------|------------------------|---------------|-------|----------|-------|
|       |         |        |                        | OUR ALGORITHM |       | LR-BASED |       |
| Input | Avg.    | Length | Length                 | # Nets        | Time  | # Nets   | Time  |
| Prob. | Spacing | Avg    | $\operatorname{stdev}$ | Failed        | (m:s) | Failed   | (m:s) |
| B1    | 3.40    | 150.1  | 39.9                   | 0             | 0:01  | 5        | 38:21 |
| B2    | 3.19    | 138.5  | 18.6                   | 0             | 0:01  | 6        | 44:52 |
| B3    | 3.46    | 151.6  | 40.1                   | 0             | 0:01  | 21       | 57:06 |
| B4    | 2.91    | 160.8  | 38.0                   | 0             | 0:01  | 4        | 46:32 |
| B5    | 3.16    | 183.9  | 30.0                   | 0             | 0:01  | 19       | 52:50 |
| B6    | 2.94    | 174.7  | 18.1                   | 0             | 0:01  | 48       | 52:45 |
| B7    | 2.12    | 157.4  | 20.7                   | 0             | 0:01  | 45       | 73:50 |
| IBM1  | 7.75    | 417.6  | 35.8                   | 3             | 0:01  | 3        | 2:29  |
| IBM2  | 6.41    | 382.0  | 46.0                   | 1             | 0:01  | 1        | 1:50  |
| IBM3  | 9.16    | 427.6  | 73.8                   | 0             | 0:01  | 0        | 7:06  |

terminals are aligned on the top and bottom sides of the channel. Since this is a vertical problem, length extension is performed on the horizontal (second) layer. Observe that nets have been assigned to tracks and their lengths have been extended so that maximum resource utilization is achieved on each track.

The experiments we have performed on test problems are given in Table I. Here, "avg. spacing" is measured in terms of the number of grid cells between terminal points of adjacent nets, and it indicates how dense the problem is.

226

On the other hand, columns "length avg" and "length stdev" give statistical information about net target lengths. Each problem in this table contains between 100 and 300 nets, with individual length constraints for each net. The grid size for the smallest circuit in this table is  $100 \times 330$ , and the largest one is  $290 \times 776$ . The last three problems here have been extracted from an IBM design, corresponding to the bus routing problems between MCM, memory, and STI modules. Here, layer assignment and routing inside chips have been performed by the previous phases of the routing system; so the input for the bus routing problem is a set of noncrossing nets on each layer. While the first 7 circuits in this table have a single layer pair, the IBM circuits have multiple layer pairs.

The results in this table indicate that our algorithm performs significantly better than the LR-based approach on most circuits, in terms of both quality and run time. The solution quality for LR-based approach degrades especially when the average spacing between nets decrease, or the target lengths increase (hence, more aggressive length extension required). The main reason for this is that the LR-based approach uses a variant of Pathfinder [Betz and Rose 1997; Ebeling et al. 1995] algorithm in the low level, where routing conflicts are resolved through *negotiations*. As the problems get denser, these negotiations take more and more time, and they do not always successfully lead to a good result. On the other hand, our algorithm performs length extension in a fast and effective way.

## 6. CONCLUSIONS

We have proposed a routing algorithm with the objective of satisfying length constraints of high-speed printed circuit boards. The main idea is to perform length extension on the secondary layer (e.g., vertical layer for a horizontal problem), where routing congestion is typically much lower than the primary layer. We have proposed an optimal algorithm to select the best subset of nets to assign to a single track, while satisfying the length constraints. Our experiments show that compared to a general Lagrangian relaxation framework, this algorithm performs considerably better on its target class of problems.

## REFERENCES

Betz, V. and Rose, J. 1997. VPr: A new packing, placement and routing tool for FPGA research. In Proceedings of the 7th International Workshop on Field-Programmable Logic. 213–222.

BLAZEWICZ, J., ECKER, K. H., AND PESCH, E. 2001. Scheduling Computer and Manufacturing Processes. Springer-Verlog, New York.

Boese, K. D., Cong, J., Kahng, A. B., Leung, K. S., and Zhou, D. 1992. On highspeed VLSI interconnects: Analysis and design. In *Proceedings of the Asia-Pacific Conference Circuits and Systems*.

Burstein, M. and Pelavin, R. 1983. Hierarchical channel router. In *Proceedings of the IEEE/ACM* 20th Design Automation Conference. ACM, New York, 591–597.

Cong, J., Kahng, A. B., Koh, C.-K., and Tsao, C.-W. A. 1998. Bounded-skew clock and steiner routing. ACM Trans. Des. Automat. Electron. Syst. 3, 3, 341–388.

Cong, J., Kahng, A. B., Robins, G., Sarrafzadeh, M., and Wong, C. K. 1992. Provably good performance-driven global routing. *IEEE Trans. Computer-Aided Des. Integ. Circ. Syst.* 11, 6, 739–752.

ACM Transactions on Design Automation of Electronic Systems, Vol. 11, No. 1, January 2006.

- CORMEN, T. H., LEISERSON, C. E., AND RIVEST, R. L. 1992. Introduction to Algorithms. MIT Press, Cambridge, MA.
- Dunlop, A. E., Agrawal, V. D., Deutsch, D. N., Jukl, M. F., Kozak, P., and Wiesel, M. 1984. Chip layout optimization using critical path weighting. In *Proceedings of the Design Automation Conference*. 133–136.
- EBELING, C., McMurchie, L., Hauck, S. A., and Burns, S. 1995. Placement and routing tools for the triptych FPGA. *IEEE Trans. VLSI*, 473–482.
- Fang, S. C., Feng, W. S., and Lee, S. L. 1992. A new efficient approach to multilayer channel routing problem. In *Proceedings of the 29th ACM/IEEE Design Automation Conference*, ACM, New York, 579–584.
- HASHIMOTO, A. AND STEVENS, J. 1971. Wire routing by optimizing channel assignment within large apertures. In *Proceedings of the of 8th IEEE Design Automation Workshop*. IEEE Computer Society Press, Los Alamitos, CA. 214–224.
- HUANG, D. J.-H., KAHNG, A. B., AND TSAO, C.-W. A. 1995. On the bounded-skew clock and steiner routing problems. In Proceedings of the 32nd ACM/IEEE Design Automation Conference, ACM, New York, 508–513.
- KAHNG, A. B. AND ROBINS, G. 1995. On Optimal Interconnections in VLSI. Kluwer Academic Publishers.
- Kuh, E., Jackson, M. A. B., and Marek-Sadowska, M. 1987. Timing-driven routing for building block layout. In *Proceedings of the IEEE International Symposium on Circuits and Systems*, IEEE Computer Society Press, Los Alamitos, CA. 518–519.
- LAPAUGH, A. S. 1980. Algorithms for integrated circuit layout: An analytic approach. Ph.D. dissertation, Laboratory for Computer Science. MIT, Cambridge, MA.
- Lee, S. and Wong, M. D. F. 2003. Timing-driven routing for FPGAs based on lagrangian relaxation. *IEEE Trans. Computer-Aided Des. Integ. Circ. Syst.*, 506–510.
- OZDAL, M. M. AND WONG, M. 2003. Length matching routing for high-speed printed circuit boards. In *Proceedings of the of IEEE International Conference on Computer-Aided Design*. IEEE Computer Society Press, Los Alamitos, CA.
- Prastjutrakul, S. and Kubitz, W. J. 1990. A timing-driven global router for custom chip design. In *Proceedings of the of IEEE International Conference on Computer-Aided Design*. IEEE Computer Society Press, Los Alamitos, CA. 48–51.
- RITCHEY, L. W. 2000. Busses: What are they and how do they work? *Printed Circuit Design Magazine*.
- RIVEST, R. L. AND FIDUCCIA, C. M. 1982. A greedy channel router. In *Proceedings of the of IEEE/ACM 19th Design Automation Conference*. IEEE Computer Society Press, Los Alamitos, CA. 418–424.
- SZYMANSKI. 1985. Dogleg channel routing is NP-complete. IEEE Trans. Computer-Aided Des. CAD-4, 1, 31–41.
- Tsao, C.-W. A. and Koh, C.-K. 2002. UST/DME: A clock tree router for general skew constraints. ACM Trans. Des. Automat. Electron. Syst. 7, 359–379.
- Yoshimura, T. and Kuh, E. S. 1982. Efficient algorithms for channel routing. *IEEE Trans. Computer-Aided Des. CAD-1*, 1, 25–35.

Received July 2004; accepted June 2005